AMENDMENTS TO CLAIMS 

This listing of claims will replace all prior versions, and listings of claims in this 
application. 

Listins o f Claims : 

1 . (Currently amended) A method to support freeform annotations, comprising: 

(a) reading and displaying a portion of a digital document on a screen based on one or 
more display properties of the screen; 

(b) accepting one or more freeform annotations on the displayed portion of the digital 
document via one or more input devices; 

(c) categorizing selecting a first categorized annotation from the one or more freeform 
annotations type where the first categorized annotation type is an anchor typ e, wherein 
the anchor intersects a word or an image in the digital document ; 

(d) categorizing selecting a second categorized annotation type where the second 
categorized annotation type is selected from the group consisting of a second anchor type 
and a comment type , wherein the second anchor intersects a word or an image in the 
digital document and wherein the comment docs not intersect a word or an image in the 
digital document ; 

(e) repeating step (d) to generate a class of annotations where each categorized annotation 
from step (d) is a member of the class of annotations, until a categorized annotation is 
categorized as the second anchor type; 

selecting another categorized annotation type where the categorized annotation type is 
selected from the group consisting of anchor type, comment type and connector type ; 

(f) categorizing a further annotation where the further categorized annotation is selected 
from the group consisting of repeating stop (o) and thereby generating categorized 
annotations of the free form annotations based on anchor types, comment types and 
connector types where the anchor types, comment types and connector types are selected 
from a predetermined set of anchor types, comment types and connector types , wherein 
the anchor type intersects a word or an image in the digital document, wherein the 
comment does not intersect a word or an image in the digital document; wherein the 
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connector type connects two anchor types, wherein a first connector connects two 
anchors ; 

(g) repeating step (f) and thereby categorizing processing the one or more freeform 
annotations based on the one or more categorized annotations via a completely 
deterministic state machine; and 

(h) indicating to the user the outcome of the processing of the one or more free-form 
annotations. 



2. (Original) The method according to claim 1, wherein: 

the method can be performed on one or more computing devices, wherein a computing 
device in the one or more computing devices can be one of: a PDA, a Tablet PC, a Pocket 
PC, a cell phone, an electronic messaging device, a Java-enabled device, a laptop or 
desktop PC, a workstation, and a mainframe computer. 



3. (Original) The method according to claim 1, wherein: 

the method can be implemented in one or more of the following programming languages: 
C, C++, Visual Basic, Java and Java Applet. 

4. (Original) The method according to claim 1, wherein: 

the digital document can include at least one of: a text file, an image, a figure, a drawing, 
a graph, a picture, and a video clip. 



5. (Original) The method according to claim 1, wherein: 

a display property in the one or more display properties of the screen can be associated 
with one of: a text font, a font size, a text color, a display width, height, and resolution of 
the screen. 



6. (Original) The method according to claim 1, wherein: 

a freeform annotation in the one or more freeform annotations can be one or more of: 
strokes, gestures and handwritings of any shape. 
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7. 



(Original) The method according to claim 1, wherein: 

an input device in the one or more input devices can be one of: a keyboard, a mouse, and 
a stylus. 



8. (Original) The method according to claim 1, further comprising: 

storing the digital document in memory and/or in a persistent storage. 

9. (Original) The method according to claim 1, wherein: 

the reading and displaying step comprises at least one of: 

utilizing the control of the Microsoft Internet Explorer; and 

accessing the Document Object Model to obtain the bounding box of the digital 
document. 

10. (Original) The method according to claim 1, further comprising: 

reserving an area on the screen for the input of the one or more freeform annotations. 

11. (Original) The method according to claim 1, further comprising: 

managing one or more annotation marks on the displayed portion of the digital document 
by performing at least one of: creating, selecting, modifying, moving, deleting, rendering, 
and displaying an annotation mark of the one or more annotation marks on the screen 
based on the one or more display properties of the screen. 

12. (Original) The method according to claim 11, wherein: 

an annotation mark in the one or more annotation marks can be one of: 

an anchor capable of associating with a part of the portion of the digital 
document; 

a link capable of connecting at least two anchors; and 

a comment capable of associating with either an anchor or a connector. 
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13. (Original) The method according to claim 12, wherein: 

the anchor can be one of: an underline, a highlight, a circled word, a circled area, a 

bracket, and a margin bar; and 

the link can be one of: an arrow, and a connector. 

14. (Original) The method according to claim 1 1, further comprising: 

storing the one or more annotation marks in memory and/or in a persistent storage. 

15. (Currently amended) The method according to claim 1 1, wherein: 

the selecting, moving, modifying, [[and]] or deleting step comprises: 

tapping, holding, [[or]] and lifting an input device in the one or more input 
devices on the annotation mark. 

16. (Original) The method according to claim 1 1, wherein: 

the rendering step comprises at least one of: 

retrieving a bounding box of the annotation mark; 
resizing and/or splitting the annotation mark; and 

repositioning the annotation mark on the portion of the digital document under 
display. 

17. (Original) The method according to claim 12, further comprising: 

reserving an area on the screen for the rendering of the comment; and/or 

resizing and/or repositioning the comment based on one of the one or more display 

properties. 

18. (Original) The method according to claim 12, further comprising: 

identifying the start of the comment by recognizing a freeform annotation in the one or 
more freeform annotations, wherein the freeform annotation is capable of: 

starting on a blank area on the digital document under display; and/or 
not intersecting with any word or image on the digital document. 
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19. (Original) The method according to claim 12, further comprising: 

identifying the finish of the comment by recognizing a freeform annotation in the one or 
more freeform annotations, wherein the freeform annotation can be one of: 

a click on a predefined area on the screen, which can be a button; 

a circular gesture around the comment; 

a strike-through gesture on the comment; 

a stroke bouncing off from the bottom of the screen; 

a special gesture that is rare in common handwriting; and 

a vertical stroke drawn on the left or right of the comment. 

20. (Currently amended) A system to support freeform annotations, comprising: 

a storage component capable of maintaining a digital document and one or more software 
components; 

a display component capable of: 

displaying a portion of the digital document based on one or more display 
properties of the display component; and 

accepting one or more freeform annotations on the displayed portion of the digital 
document via one or more input devices; 
a processor categorizing component capable of categorizing the one - or more frooform 
annotations, wherein the categorized component is based on one or more of anchor types, 
comment types and connector types where the anchor types, comment types and connector types 
arc selected from a predetermined set of anchor types, comment types and connector types and 
indicating to the user the category of the one or more free form annotations; and — 

a processing component capable of processing the one or more freeform annotations 
based on the one or more categorized component via a completely deterministic state machine; 

(a) wherein the processor first categorizes a freeform annotations as a first anchor type, 
wherein the first anchor type intersects a word or an image in the digital document; 

(b) wherein the processor next categorizes a freeform annotations as a second anchor type 
or a comment type, wherein the second anchor type intersects a word or an image in the digital 
document and wherein the comment type does not intersect a word or an image in the digital 
document; 
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(c) wherein the processor thereafter repeats step (b) unless a second anchor type is 
processed; 

(d) wherein the processor thereafter categorizes freeform annotations as an anchor type or 
a comment type or a connector type, wherein the anchor type intersects a word or an image in the 
digital document, wherein the comment does not intersect a word or an image in the digital 
document; wherein the connector type connects two anchor types, wherein the first connector 
type connects the first anchor type and the second anchor type . 

21. (Original) The system according to claim 20, wherein: 

the system can be part of one or more computing devices, wherein a computing device in 
the one or more computing devices can be one of: a PDA, a Tablet PC, a Pocket PC, a 
cell phone, an electronic messaging device, a Java-enabled device, a laptop or desktop 
PC, a workstation, and a mainframe computer. 

22. (Original) The system according to claim 20, wherein: 

the storage component can be a memory or a persistent storage. 

23. (Original) The system according to claim 20, wherein: 

the display component can be a screen, which can be a LCD or a CRT monitor. 

24. (Original) The system according to claim 20, wherein: 

the processing component can be a CPU, an embedded CPU, or a MCU. 

25. (Original) The system according to claim 20, wherein: 

the digital document can include at least one of: a text file, an image, a figure, a drawing, 
a graph, a picture, and a video clip. 

26. (Original) The system according to claim 20, wherein: 
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a software component in the one or more software components can be implemented in 
one or more of the following programming languages: C, C++, Visual Basic, Java and 
Java Applet. 

27. (Original) The system according to claim 20, wherein: 

a display property in the one or more display properties of the display component can be 
associated with one of: a text font, a font size, a text color, a display width, height, and 
resolution of the display component. 

28. (Original) The system according to claim 20, wherein: 

an input device in the one or more input devices can be one of: a keyboard, a mouse, and 
a stylus. 

29. (Original) The system according to claim 20, wherein: 

a freeform annotation in the one or more freeform annotations can be one or more of: 
strokes, gestures and handwritings of any shape. 

30. (Original) The system according to claim 20, wherein: 

the display component is further capable of: 

utilizing the control of the Microsoft Internet Explorer; and 

accessing the Document Object Model to obtain a bounding box of the digital 
document. 

3 1 . (Original) The system according to claim 20, wherein: 

the display component is further capable of reserving an area on the display component 
for the input of the one or more freeform annotations. 

32. (Original) The system according to claim 20, wherein: 

the processing component is further capable of: 

managing one or more annotation marks on the displayed portion of the digital 

document by performing at least one of: creating, selecting, modifying, moving, 
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deleting, rendering, and displaying an annotation mark of the one or more annotation 
marks on the display component based on the one or more display properties of the 
display component. 



33. (Original) The system according to claim 32, wherein: 

an annotation mark in the one or more annotation marks can be one of: 

an anchor capable of associating with a part of the portion of the digital 
document; 

a link capable of connecting at least two anchors; and 

a comment capable of associating with either an anchor or a connector. 

34. (Original) The system according to claim 33, wherein: 

the anchor can be one of: an underline, a highlight, a circled word, a circled area, a 

bracket, and a margin bar; and 

the link can be one of: an arrow, and a connector. 

35. (Original) The system according to claim 32, wherein: 

the storage component is further capable of maintaining the one or more annotation 
marks. 

36. (Original) The system according to claim 32, wherein: 

the processing component is further capable of performing at least one of: selecting, 
moving, modifying, and deleting the annotation mark, via tapping, holding, and lifting an 
input device in the one or more input devices on the annotation mark. 



37. (Original) The system according to claim 32, wherein: 

the processing component is further capable of rendering the annotation mark via at least 
one of: 

retrieving a bounding box of the annotation mark; 
resizing and/or splitting the annotation mark; and 
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repositioning the annotation mark on the portion of the digital document under 
display. 



38. (Original) The system according to claim 33, wherein: 

the processing component is further capable of rendering the comment by: 

reserving an area on the screen for the rendering of the comment; and/or 

resizing and/or repositioning the comment based on one of the one or more display 

properties. 

39. (Original) The system according to claim 33, wherein: 

the processing component is further capable of identifying the start of the comment by 
recognizing a freeform annotation in the one or more freeform annotations, wherein the 
freeform annotation is capable of: 

starting on a blank area on the digital document under display; and/or 
not intersecting with any word or image on the digital document. 

40. (Original) The system according to claim 33, wherein: 

the processing component is further capable of identifying the finish of the comment by 
recognizing a freeform annotation in the one or more freeform annotations, wherein the 
freeform annotation can be one of: 

a click on a predefined area on the screen, which can be a button; 

a circular gesture around the comment; 

a strike-through gesture on the comment; 

a stroke bouncing off from the bottom of the screen; 

a special gesture that is rare in common handwriting; and 
a vertical stroke drawn on the left or right of the comment. 



41. (Currently amended)) A machine readable medium having instructions stored thereon that 
when executed by a processor cause a system to: 

read and display a portion of a digital document on a screen based on one or more display 
properties of the screen; 
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accept one or more freeform annotations on the displayed portion of the digital document 
via one or more input devices; 

categorize the one or more freeform annotations, wherein the categorizing is based on 
one or more of anchor types, comment types and connector types where the anchor types, 
comment types and connector types are selected from a predetermined set of anchor 
types, comment types and connector types and indicate to a user the category of the one 
or more free-form annotations; 

(a) wherein the processor first processes a freeform annotations as a first anchor type, 
wherein the first anchor type intersects a word or an image in the digital document; 

(b) wherein the processor next processes a freeform annotations as a second anchor type 
or a comment type, wherein the second anchor type intersects a word or an image in the digital 
document and wherein the comment type does not intersect a word or an image in the digital 
document; 

(c) wherein the processor thereafter repeats step (b) unless a second anchor type is 
processed; 

(d) wherein the processor thereafter processes freeform annotations as an anchor type or a 
comment type or a connector type, wherein the anchor type intersects a word or an image 
in the digital document, wherein the comment docs not intersect a word or an imauc in 
the digital document; wherein the connector type connects two anchor types, wherein the 
first connector type connects the first anchor type and the second anchor type ; and 
process the one or more free - form annotations based on the categorizing via a completely 
deterministic state machine . 

42. (Original) The machine readable medium of claim 41, wherein: 

the instructions can be embedded and executed on one or more computing devices, 
wherein a computing device in the one or more computing devices can be one of: a PDA, 
a Tablet PC, a Pocket PC, a cell phone, an electronic messaging device, a Java-enabled 
device, a laptop or desktop PC, a workstation, and a mainframe computer. 

43. (Original) The machine readable medium of claim 41, wherein: 
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the instructions can be implemented in one or more of the following programming 
languages: C, C++, Visual Basic, Java and Java Applet. 

44. (Original) The machine readable medium of claim 41, wherein: 

the digital document can include at least one of: a text file, an image, a figure, a drawing, 
a graph, a picture, and a video clip. 

45. (Original) The machine readable medium of claim 41, wherein: 

a display property in the one or more display properties of the screen can be associated 
with one of: a text font, a font size, a text color, a display width, height, and resolution of 
the screen. 

46. (Original) The machine readable medium of claim 41, wherein: 

a freeform annotation in the one or more frecform annotations can be one or more of: 
strokes, gestures and handwritings of any shape. 

47. (Original) The machine readable medium of claim 41, wherein: 

an input device in the one or more input devices can be one of: a keyboard, a mouse, and 
a stylus. 

48. (Original) The machine readable medium of claim 41, further comprising instructions that 
when executed cause the system to: 

store the digital document in memory and/or in a persistent storage. 

49. (Original) The machine readable medium of claim 41, further comprising instructions that 
when executed cause the system to: 

utilize the control of the Microsoft Internet Explorer to read the digital document; and 
access the Document Object Model to obtain the one or more display properties. 

50. (Original) The machine readable medium of claim 41, further comprising instructions that 
when executed cause the system to: 
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reserve an area on the screen for the input of the one or more freeform annotations. 



51. (Original) The machine readable medium of claim 41, further comprising instructions that 

when executed cause the system to: 

manage one or more annotation marks on the displayed portion of the digital document 
by performing at least one of: creating, selecting, modifying, moving, deleting, rendering, 
and displaying an annotation mark of the one or more annotation marks on the screen 
based on the one or more display properties of the screen. 



52. (Original) The machine readable medium of claim 51, wherein: 

an annotation mark in the one or more annotation marks can be one of: 

an anchor capable of associating with the portion of the digital document; 

a link capable of connecting at least two anchors; and 

a comment capable of associating with cither an anchor or a connector. 

53. (Original) The machine readable medium of claim 52, wherein: 

the anchor can be one of: an underline, a highlight, a circled word, a circled area, a 

bracket, and a margin bar; and 

the link can be one of: an arrow, and a connector. 



54. (Original) The machine readable medium of claim 51, further comprising instructions that 
when executed cause the system to: 

store the one or more annotation marks in memory and/or in a persistent storage. 

55. (Original) The machine readable medium of claim 51, further comprising instructions that 
when executed cause the system to: 

perform at least one of: selecting, moving, modifying, and deleting the annotation mark 
via tapping, holding, and lifting an input device in the one or more input devices on the 
annotation mark. 
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56. (Original) The machine readable medium of claim 51, further comprising instructions that 
when executed cause the system to: 

render the annotation mark via at least one of: 

retrieving a bounding box of the annotation mark; 
resizing and/or splitting the annotation mark; and 

repositioning the annotation mark on the portion of the digital document under 
display. 

57. (Original) The machine readable medium of claim 52, further comprising instructions that 
when executed cause the system to: 

reserve an area on the screen for the rendering of the comment; and/or 

resize and/or reposition the comment based on one of the one or more display properties. 

58. (Original) The machine readable medium of claim 52, further comprising instructions that 
when executed cause the system to: 

identify the start of the comment by recognizing a freeform annotation in the one or more 
frccform annotations, wherein the freeform annotation is capable of: 

starting on a blank area on the digital document under display; and/or 
not intersecting with any word or image on the digital document. 

59. (Original) The machine readable medium of claim 52, further comprising instructions that 
when executed cause the system to: 

identify the finish of the comment by recognizing a freeform annotation in the one or 
more freeform annotations, wherein the freeform annotation can be one of: 

a click on a predefined area on the screen, which can be a button; 

a circular gesture around the comment; 

a strike-through gesture on the comment; 

a stroke bouncing off from the bottom of the screen; 

a special gesture that is rare in common handwriting; and 

a vertical stroke drawn on the left or right of the comment. 
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60. (Previously presented) A system for managing versions of a software component, 
comprising: 

means for reading and displaying a portion of a digital document on a screen based on 
one or more display properties of the screen; 

means for accepting one or more categorized annotations of the one or more freeform 
annotations on the displayed portion of the digital document based on one or more of anchor 
types, comment types and connector types where the anchor types, comment types and connector 
types are selected from a predetermined set of anchor types, comment types and connector types 
via one or more input devices; and 

means for processing the one or more freeform annotations based on the one or more 
categorized annotations via a completely deterministic state machine. 

61. (Previously presented) A computer data signal embodied in a transmission medium, 
comprising: 

a code segment including instructions to read and display a portion of a digital document 
on a screen based on one or more display properties of the screen; 

a code segment including instructions to accept one or more categorized annotations of 
the one or more freeform annotations on the displayed portion of the digital document based on 
one or more of anchor types, comment types and connector types where the anchor types, 
comment types and connector types are selected from a predetermined set of anchor types, 
comment types and connector types via one or more input devices; and 

a code segment including instructions to process the one or more freeform annotations 
based on the one or more categorized annotations via a completely deterministic state machine. 
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